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® Method and system for improving the processing time of the path selection in a high speed pacKet 
switching network. 

efficiently by reducing the total ^^^^^^^ and the second phase for 

technique involves two ^^^^^^^^^^^^ paths are mlnirT.um hop count paths with a 

selection of the best pomt-to-po.nt ^^^.^'"J^^^^^ Hmits the screening of the network links in the 

transmission delay less than a specified threshold^The ^'Q^^'^^J^ exploration of a much smaller number 

second phase to the principal ^^^'^.^^^^^^ path selection. The fact 

aTowsTo l^it the additional processing time necessary in case of unsuccessful attempt. 
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Technical field 

The present invention relates to a high speed transmission system in a large packet switching network 
and. more particularly, to an apparatus and a method for accelerating the path selection between a source 
5 and a destination node by reducing the total number of links potentially explored by the Modified Bellman- 
Ford Algorithm. 

Background art 

10 It has become increasingly useful to interconnect a plurality of data processing elements by means of a 

packet switching network in which data is transmitted as data assemblages called "packets". Such networks 
include a plurality of interconnected switching nodes which, in turn, are connected to end nodes supporting 
data processing equipments. Such packet networks can become quite large with an extensive geographical 
distribution. In such a situation, the selection of an efficient path between two end nodes which wish to 

;5 communicate with each other becomes of paramount importance. Different methods are summarized by H. 
Nussbaumer in Teleinformatique U (pages 92 to 117) Presses Polytechniques Romandes 1987. 

Path Selection 

20 The general problem which must be solved at the network level is to find a path between a source and 

a destination node. When the network is using datagrams, the path selection must be done individually for 
each packet. For virtual circuits, the path decision is done once only at the time of the circuit establishment. 
In both cases, the choice of a routing algorithm is not easy because it must satisfy a large number of often 
conflicting requirements. This algorithm must be simple to implement to not complicate the nodes 

25 realization, it must ensure a correct progress of the packets whatever the disturbance on the network. The 
algorithm must be able to provide satisfying results despite of the traffic variations and the network 
topology. It must also ensure the equity between the different end users and provide an equal distribution of 
the rights to access the network. At last, the routing algorithm must allow, when possible, to exploit the 
network in an optimal way, according to a criterion which can vary with the utilization type. In most of the 

30 cases, the network is realized in a way to minimize the packet transit time and to transfer the maximum 
number of packets. In other cases, the objective is to decrease the communication cost, or to develop a 
reliable network able to operate correctly either in case of catastrophic line, node failure or peaks of traffic. 

Because of the variety of the constraints, there are a large number of different routing types like 
Floading Routing. Random or Stochastic Routing, Deterministic Routing. This last technique is one of the 

35 most widely used. Two modes of operation are opposed : the Fixed Routing and the Adaptive Routing. 

Fixed Routing 

The Fixed Routing defines paths that must take the different packets according to the general network 
40 characteristics such as the network topology and the mean traffic expected on the communication lines. 
The routing rules are established once and aims for optimizing the performance criterion privileged by the 
user. The Fixed Routing is very simple in its principles and allows to considerably speed up the packet 
transmission through the network. 

45 Adaptive Routing 

Contrary to the Fixed Routing, the purpose of the Adaptive Routing is to satisfy at any time the 
optimization criterion. The tables are permanently updated according to, for example, the instantaneous 
state of the traffic on the lines. 
50 • Centralized Routing 

When the characteristics of the network fluctuate, it is possible to adapt the routing by assigning 
to one node the responsibility to update periodically the routing tables according to the traffic 
variations and the topology. This method, simple in its principles, is called Centralized Routing. Its 
principal disadvantage is to generate an important auxiliary traffic and to subordinate the good 
55 functioning of the network to only one node. Furthermore, the Centralized Routing can generate some 

problems at the time the tables are refreshed because said tables cannot be received at the same 
time by all the nodes. A solution is to decentralize the tables establishment at the level of each node. 
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* Th? loS and distributed routing methods are both based on the establishment by each node of 

be minimal. 

' °''Te*1lstribS Routing is a local method in which neighboring nodes are exchanging messages 
concerning L traffic and L network condition to update their rout.ng and delay tables. 

High Performance Networks 

engineering workstations, terminals and small '^J^'^J'^^'l'^'^ '^^^^^ networks architectures in 

through a common set of nodes and links. 
Throughput 

.-^iir=™i^^ 

Zr^^Z:::^t:^^Z^Z.J^ hlh speed networks is to minimize the 
packet processing time wJtN ^^^^^.^^ ^^^^^^^.^^ ^^^^ , ^,PS (Millions of 

For example (Figure i ). taKing <* . j packets even if a network node 

: Instructions Per Second), .t .s possible to f.M a 9.6 kbp^jne with P 000 

must execute 833 ^00 ^^nsU.a^'^s^^^^^^^^^ , 
rnSrs Z in the ^r imn'rcSJ rate of f 0-30 MIPS would allow only 70.00 

instructions per packet. oHv;*ntarie of the hiqh speed/low error rate 

architectures are performed on an end-to-end basis. 



Routing Modes 
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The routing within the network presents two aspects : 
1 Determining what the route for a given connection shall be. 

MlLt.o^'^S^-Hpre. » 'O '« - OG«-»,«-00 .rSC R,,.*-. «a™« ~ ,o„,,ng .odes 
me most iy used a™ the Source Routing and » Label S»apt«n9^ 

■ ^^"^LTut^ Routing is a particular implemenlalion ol tl,e Distributed Routing for connactlonless 
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through the network as a self contained unit and is Independent of all other packets. The key point for 
the source node is to deternnine for each datagram the optimal route In the shorter lapse of time. 

• Label Swapping 

The Label Swapping is a particular implementation of the Distributed Routing for connection 
5 oriented networks. These networks typically multiplex many connections (or sessions) on a link using 

some form of logical "channel". Each packet sent on the link has a header which includes an arbitrary 
number identifying which logical connection that this packet belongs to. 

The call set up and the resource reservation process comprises the following steps : 

■ A connection request is specified by the user via a set of parameters including origin and 
10 destination address and data flow characteristics. 

■ The path determination is realized by the source node from its local routing Topology Database 

■ The route reservation is sent out in a special message along the specified nodes. Said message, 
which is usually routed according to the previously described Source Routing technique, signals 
the nodes to set up their connection tables and to reserve their resources to provide the level of 

75 service required by the traffic type (for example, a bandwidth reservation on each of the links of the 

path). 

■ The tables update reflects the changes in the availability of the network resources. The 
information is sent to every node in the network. 

The Label Swapping technique requires that the connection tables be set up and maintained dynam- 
20 ically. That means that when a new connection is established or an old one is terminated the tables are 
updated (the database of network topology can of course be maintained quite separately). This is possible if 
the connection set up is relatively infrequent and is not too time critical. This restriction makes datagram 
transport quite inefficient. However, connections that require very short packets, like real-time voice 
connections, can be effectively supported by this technique, because of the low packet overhead. Alt is 
25 needed is a field to specify which connection is to be used for the packet 

Key requirements 

The Distributed Routing mechanism in large and high speed packet switching networks supporting both 
30 connection oriented and connectionless routing modes implies some requirements in terms of performance 
and resource consumption which can be summarized as follows : 

• the source node (or the node providing the route calculation for the source node) must be able to 
decide where to route an incoming packet in a very short portion of time (the computation must be 
sufficiently rapid to compute an optimum path for each connection request) 

35 • the switching time in the intermediate nodes must be minimized, (minimum processing time) 

• the network resources along the selected path must be optimized according to the customer 
criterions. 

• Control messages must be as much as possible limited not to overload the network. 
40 Path Seiection Criterions 

Bellman-Ford Algorithm 

There are several possible adaptive routing algorithms to compute an optimal path between nodes In a 
45 packet network. The Bellman-Ford algorithm described by D. Bertsel<as and R. Galiager in Data 
Networks - Prentice- Hall 1987 Englewood Cliffs, New Jersey - is one of the most currently used in 
fast packet packet switching networks. The objective of the algorithm is to find a path joining two nodes with 
the minimum length, the length being defined to reflect the congestion of the link. The algorithm starts from 
the source node and first find the shortest path lengths subject to the constraint that the paths contain at 
50 most one link. Then. It find the shortest path lengths with a constraint of paths of at most two links, and so 
forth. 
Let 

• N the number of nodes (labeled 1 »2 N). 

• M the number of unidirectional links. 

55 It is assumed that there is at most one unidirectional link going from one node to another, and so 

a link can be identified by Its end points. 

• h the number of hops. 
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. D (i h) the shortest (ih) path length from source r^ode (1) to node (.). 

By convention D (1 .h) = 0 for all h. 
. d« the length of the link connecting node (i) to node H). 

' By convention d« = ~ if nodes (i) is not connected to node 0)- 
Initially D(/,0) = « for all /" * 1 
For each successive Oi h , 

+ ^. = rr^\HO(hh) + d«] . i = 1 N for all i * 1 

Let D(l) be the shortest path length from node (1) to 0), wiin uv , 
h = N-1 and can be written : 

D(0 = minUDU) + dal for all / * 1 

0(1) = 0 jhat tho shortest oath length from node (1) to (i) is 

the path. 

Modified Bellman-Ford Algorithm 

.3 described with the Be.lman-Pord -9—^^^^^ 
nodes in packet networks is the mmimum patt^ ^"^^J^/^J^P^^^^^^^^^^^ delay imposed by the path between 
,n most of the cases, the length .s a funcfon °* *f J'^^^'tength) is not a major consideration since 

the two end nodes. In most high speed networks. '""^ ^^^^^^fj^^^^^^ y^e hop count, however, is a 
the worst-case delay through such networks ^^^^^^^^^^J^^^^^^^^ 

direct measure of the amount of resources '^^'^^^.f links used to construct the path 

ia,portance in selecting paths. The hop fJ'^^^^^ J^'^Jhop count path since congestion on the 

between two nodes. A selected path 7^^^"°* f J^^^'^^^^^ such longer alternate paths cannot 
network links may force the choice of a '^^^ n?ight be committed to one 

be allowed to grow without limit smce hop count paths to be selected 

path, resulting in further congestion for other paths and fojanQ °ngj 3,^^,3^,^ effected. The 

tor yet other connections. The long term netwo k thr°"9hP"t cou dj y ^ ^.^.^^^ 

problem, then, is to select a path between ^" network resources. 

Lnt. a minimum path length, which does not utiltze an mordina^^^^^ ^^^^^^ 

The goal of the Modified Bel-man-Ford agor,t m^^^^^^^ thfsourand the destination node 

destination node pair, with a ""'"''^'j/.f^*^^'^^^ node and progresses by increasing 

and with a minimum path length. The ^f°;f';;;';'}^J'Z^^^^^^^ count h, the algorithm finds 

the hop count (the number of links) ^^'^^ '^J^'"'^^^^^'^^^^^ h links. 

i:t^S)?e node . with ..... . hops . 

D{i.h) = min,{D(y,h - l) + d„] . i = 1 N for all i* 1 

i5 European Patent Application 93480030.1 
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and destination nodes by means of a improvennent of the Modified Bellman-Ford algorithm. The method 
defines "principal paths" between any given origin-destination pair. A principal path is defined as a feasible 
minimum-hop count path and principal links are defined as links in a principal path. All other links are 
defined as secondary links. Secondary paths are paths including at least one secondary link and including 
5 more than the minimum-hop count. 

• A principal path is accepted as a route if none of its principal links is saturated, that means exceeds 
its preassigned traffic load. 

• A secondary path, however, is accepted as a route only if none of its principal links, if any, is 
saturated and if the load levels on its secondary links are below a preselected threshold (typically 

10 lower than that for links designated as principal). If this load threshold is exceeded on any of the 

secondary links, the secondary path is rejected as a route. 
One advantage of the path selection technique of this invention is that a maximum path length 
constraint can be imposed on the path selection process. That is. feasible paths can be tested to determine 
if the path length constraint has been exceeded and rejected if the constraint is exceeded. Such constraints 
rs can be used to prohibit inordinate resource consumption in implementing a route and can also be used to 
impose specific grade of service requirements such as avoidance of low speed links. For this reason, the 
path length constraints must typically be specified for each connection request, and the principal links 
determined separately for each connection request. 

The algorithm is invoked with some of the following parameters : 
20 • the source node address, 

• the destination node address, 

• the quality of service required for the connection. For example : 

■ maximum call set up delay (very important parameter for connections serviced in real time). 

■ maximum end to end transit delay, 

25 ■ maximum information loss, error probability, 

■ ... 

The algorithm uses in the source node (or access node) a local copy of the network topology to 
determine the minimum hop and path length to the destination node. 

The route selection technique of European Patent Application 93480030.1 involves two phases. In the 
30 first phase, the principal links are identified for the requested connection. If no maximum length constraint is 
imposed, the principal links between any two nodes of the network can be precomputed and stored for use 
in the second phase of the algorithm. If a maximum length constraint is imposed, the principal links must be 
calculated for each new connection request, comparing each link length with the constraint, or the constraint 
decreased by the previously accepted principal link lengths. 
35 This route determination technique has the advantages of producing optimum paths between arbitrary 

nodes of a packet switching system, taking into account not only the hop count and the path length, but 
also imposing a maximum ceiling on the path length. 

But the problem is to compute the paths sufficiently rapidly so that an optimum route can be selected - 
for each connection request. 

40 

Summary of the invention 

In accordance with the illustrative embodiment of the present invention, optimum routing paths between 
origin and destination nodes in a packet network are selected more efficiently by reducing the total number 
45 of links potentially explored by the Modified Bellman-Ford Algorithm described in the European Patent 
Application 93480030.1. The path selection technique of the present invention involves two phases, the first 
phase for principal links identification, and the second phase for selection of the best point-to-point path in 
the network. 

More particularly, the algorithm of the present invention limits the screening of the network links In the 
50 second phase to the principal links and excludes the secondary links. The exploration of a much smaller 
number of links has the advantage to considerably reduce the computation time required for the p^th 
selection. The fact the number of principal links is generally small compared with the total number of links 
potentially explored, allows to limit the additional processing time necessary in case of unsuccessful 
attempt. 

55 In summary, the present invention discloses a system and a method for determining an optimal routing 
path between an originating and a destination node in a network. Said method involves the steps of : 

• storing and updating the network configuration, 

• in a first phase : 
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. identifying principal paths including minimal hop count and minimal transmission delay between 
said originating nod© and said destination node in said network. 

. :j£SSST^^'~^ .« ^ -p »■ '~ 

an optimal path between said originating and destination nodes, 
and is characterized in that it further comprises the steps of : 

. riftterminina in said second phase, an optimal path using only pnncipal links. 

: SSnlng. lerl the destination node is not reached using said principal links, an optimal path using 

, sails' oTdeTeJ^ntga^tptimal path on principal and secondary links, is using |ink utilization data 
prev^'sly computeton principal links by said step of determining an optimal path on said pnncpal links. 

Description of the drawings 

Figure 1 shows the processing times (or number of instructions per second) required in function of the 
— . iraCSS^ o? ritTptr rwit^ing network including the access and transit 

Point according to the present invention. 
,0 Figure 4 shows a portion of the Topology Database in each Routing Pointy the present 

Figure 5 shows a general flow chart of the path determination procedure according to the present 

""ngu'e 6 Shows a detailed flow chart of the accelerated option of Phase 2 according to the present , 

.5 '"'ni'e 7 Shows a detailed flow chart of the conventional option of Phase 2 according to the present 

'"'Sgu^e 8 shows a more detailed flow chart of Routine A1 of the Phase 2 accelerated search algorithm 

^^Cr9Th?wra~;:L tlow chart of Routine A2 of the Phase 2 conventional search algorithm 

30 according to the present invention. 

35 Milano in a conventional path search according to the present invention. 



Descf/p«on of the preferred embodiment of the invention 

As illustrated in Figure 2. a typical model of communication system is made of several user networks 

i,X r„t; b. inwcon^cd .h,ou,h wM. a.« transport « 

pran. in-enSetoilSs assenL^ .o .h. I.«.r caBgor, and mora panicula,., to tha fast paoke, sw„ch.n9 

network architecture detailed in the following paragraphs. 

High speed packet switching networks 

The qeneral view in Figure 2 shows a fast packet switching transmission system comprising eigh^ 

(202 to 205) located at the periphery. These Access Nodes comprise one or more Ports, each 
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providing an access point for attaching external devices supporting standard interfaces to the network and 
performing the conversions required to transport the users data flow across the network from and to other 
external devices. As example, the Access Node 202 interfaces respectively a Private Branch exchange 
(PBX), an application server and a hub through three Ports and communicates through the network by 
5 means of the adjacent Transit Nodes 201 . 208 and 205. 

Switching Nodes 

Each network node (201 to 208) includes a Routing Point where the incoming data packets are 
10 selectively routed on the outgoing Trunks towards the neighboring Transit Nodes. Such routing decisions 
are made according to the information contained in the header of the data packets. In addition to the basic 
packet routing function, the network nodes also provide ancillary services such as : 

• the determination of routing paths for packets originated in the node, 

• directory services like retrieving and updating information about network users and resources, 

75 • the maintaining of a consistent view of the physical network topology, including link utilization 
information, and 

• the reservation of resources at access points of the network. 

Each Port is connected to a plurality of user processing equipments, each user equipment comprising 
either a source of digital data to be transmitted to another user system, or a data sink for consuming digital 
20 data received from another user system, or, typically, both. The interpretation of the users protocols, the 
translation of the users data into packets formatted appropriately for their transmission on the packet 
network (200) and the generation of a header to route these packets are executed by an Access Agent 
running in the Port. This header is made of Control and Routing Fields. 

• The Routing Fields contain alt the information necessary to route the packet through the network (200) 
25 to the destination node to which it is addressed. 

• The Control Fields include, among other things, an encoded identification of the protocol to be used in 
interpreting the Routing Field (Source Routing, Label Swapping ). 

Routing Points 

30 

Figure 3 shows a general block diagram of a typical Routing Point (300) such as it can be found in the 
network nodes (201 to 208) illustrated in Figure 2. A Routing Point comprises a high speed packet Switch 

(302) onto which packets arriving at the Routing Point are entered. Such packets are received : 

• from other nodes over high speed transmission links (303) via Trunk Adapters (304), 
35 • from users via application adapters called Ports (301). 

Using information In the packet header, the adapters (304. 301) determine which packets are to be 
routed by means of the Switch (302) towards a local user network (307) or towards a transmission link 

(303) leaving the node. The adapters (301 and 304) include queuing circuits for queuing packets prior to or 
subsequent to their launch on the Switch (302). 

40 The Route Controller (305) calculates the optimum routes through the network (200) so as to satisfy a 
given set of quality of service specified by the user and to minimize the amount of network resources used 
to complete the communication path. Then, it builds the header of the packets generated in the Routing 
Point. The optimization criterion includes the number of intermediate nodes, the characteristics of the 
connection request, the capabilities and the utilization of the Trunks in the path ... All the information 

45 necessary for the routing, about the nodes and transmission links connected to the nodes, are contained in 
a Network Topology Database (306). Under steady state conditions, every Routing Point has the same view 
of the network. The network topology information is updated when new links are activated, new nodes 
added to the network, when links or nodes are dropped or when link loads change significantly. Such 
information is originated at the network node to which the resources are attached and is exchanged by 

so means of control messages with all other Route Controllers to provide the up-to-date topological information 
needed for route calculation (such database updates are carried on packets very similar to the data packets 
exchanged between end users of the network). The fact that the network topology is kept current in every 
node through continuous updates allows dynamic network reconfigurations without disrupting end users 
logical connections (sessions). 

55 The incoming transmission links to the packet Routing Point may comprise links from external devices 
in the local user networks (210) or links (Trunks) from adjacent network nodes (209). In any case, the 
Routing Point operates in the same manner to receive each data packet and forward it on to another 
Routing Point as dictated by the information in the packet header. The fast packet switching network 
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Topology Database Database 306. The 

Load Threshold ^.^^^ Load Threshold 

US), are defined for eacn i « 

a route or as a secondary l.nk.n the route. 

Principal and Secondary links ^^^^.^^^ ^.^.^^^ 

40 Total Allocated Load represents the total load 

whether the link is a prmapal link ^^^^ maximum 

link cannot be selected. Application 93480030.1 the P^^^ent .nvent.o abaters 

Route Oeierminaiion 
Route request 

^ ,0, . — - 

• Source Node (0 

♦ Destination Node 0) 
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• Required Bandwidth (c) 

• Maximum Path Length Threshold (Pt) 

• Quality of Service Parameters (QOS) (Optional) 

The requested maximum path transmission delay is generally taken as Path Length Threshold (Pt). Using 
5 these parameters, a path is determined by first searching through all links to determine minimum hop count 
path that satisfy the maximum path length constraint Pt and then backtracking to derive a list of principal 
links. This search is supplemented by accumulating the link delays dht for each path. Once the destination 
node is reached, minimum hop count principal paths are backtracked to create a list of principal links. This 
principal link list is used in the second phase of the algorithm to determine the optimum path from the 
70 source to the destination node. This specific procedure for determining paths through a packet communica- 
tions system will be described with reference to Figures 5, 6, 7, 8 and 9. 

Path Determination Procedure 

15 Figure 5 shows a general flow chart of the path determination procedure according to the present 

invention. 

1. Data Input (501) 

Starting at 500, step 501 first specifies the inputs- required to calculate an optimum route. As noted 
above, these input parameters include the originating node (t), the destination node (j), the requested 
20 connection bandwidth (c) and the maximum Path Length Threshold Pt (and optionally a group of Quality 
Of Service (QOS) parameters). 

2. Phase 0 (502) : Bandwidth Requirements 

The list of links in the network is pruned by removing all links which do not meet the required 
bandwidth c (ct Cm) and the Quality Of Service (QOS) parameters. 
25 3. Phase 1 (503) : Principal and Secondary Links Search 

With this decimated list of transmission links, the function of Phase 1 (503) is to identify the principal 
links. In determinating the lengths of the transmission links Zduh the process assumes that the utilization 
of each link is zero 

(C,/ = 0). 

which means that the entire bandwidth of the link is available. The process used to search for principal 
paths is the Modified Bellman-Ford Algorithm described in Patent Application 93480030.1. 
36 4. Phase 2 (504) : Optimum Path Computation 

Once the principal paths have been identified (503), the function of Phase 2 (504) is to identify the 
optimum path, using the principal paths from Phase 1 (503), and the current utilization data (allocated 
bandwidth Cm). It exists two different options for Phase 2, an Accelerated Version and a Conventional 
Version : 

40 • The Conventional Version is similar to Phase 2 described in Patent Application 93480030.1, 

• The Accelerated Version, object of the present invention, represents a significant improvement in 
the process of the path selection by limiting the screening of the network to the principal links. This 
version will be described in detail hereafter. 
5. Acceptable Path Determination (505) 
45 As noted in 505, the output of Phase 2 (504) is an acceptable minimum hop count path from the 

originating node (i) to the destination node (j) if it has the minimum possible hop count and if its path 
length is less than the input maximum of Pt (^dkt ^ ^r). If no such path exists, a failure signal is returned. 
The process ends in 506. 

Note : No detailed flow chart of Phase 1 is shown due to the fact that this phase is strictly identical to 
50 the one described in Figure 6 of Patent Application 93480030.1 

Phase 2 

1 . Accelerated Version 

55 Figure 6 shows a more detailed flow chart of the Accelerated Version of Phase 2 where the optimum 

path is computed. Starting in 600, Routine A1 (601), similar to Routine A in Phase 1, is executed. 
Routine A1 uses the same modified Bellman-Ford Algorithm to determine the feasibility and the link 
length for each possible link in the ultimate path. The main difference resides in the fact that only 
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. ^ .H r Secondary links are not considered. If the 
does not exceed the principal link load ^^^^^^^^^^^^^ pjcess switches to the conventional 

2. conventional Version ^i^h the optimum path is computed. The 

Figure 7 shows a more detailed flow chart °' '"^ig^ated (701 , 704) and a Conventional (703. 

Phas?2, according to the present invent.on jncludes an Accelere^e (^^^^^ 

704) Version. The Conventional Version '^^.^^^^ P^^f J' desired path. Phase 2 starts in 700 w.th the 
does not succeed in reaching the destmat.on n°de of *e des^ P ^^^^.^^ ^^^^^ (^3^,3^^ 

accelera ed version. If the destination node .s "^Vh^^^*^^^^^^^^^^^ a feasible principal path. Routme 
oSnt 702) after all principal links have been '^^f^^^^lZ^M method described in European 
'a2 (70S) is executed. Routine A2 o^r.^es acc^^n,^^^^^^^ Td secondary links : secondary links are 
Patent Application 93480030.1. " ^^^^'^^^^/.^J^ Jew connection does not result in exceed.ng the 
accepted' as feasible P-v^ded that ^ddms * e new co^^ ^^^^^.^^ ^^^^ ^„ ,,ec/r,ngs and 
secondary link load threshold C.,s- However 



computations related to 
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. rrr.^ Thc.t le thp rsason whv the chaining of 

m7» RouB^S, A. (701) ana A2 C703). does "« » „„„„ „480030... In sW 704, 

European Patent Application 93480030.1_ ^ „, «celerated and 
. rn. Ba«ack., Pr«.*» ns^^^^^^^^ rer.n\ tne =a™ as tne one d..*,d In .9u,e 0 o, 
SrptteTtA^Lir^^SaooM... 

Search Algorithm 

1 Accelerated Version (Routine A1) Bellman-Ford Algorithm used to perform the 

Figure 8 shows a detailed flow chart of ."^ gOI first sets the next node to the or.gin 
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The accumulated load 
iscomputedinstep812-liThen. 
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is compared to the link principal tliresliold C^.p : 
5 A If the accumulated load is equal to or less than the principal threshold. 

(CiV < C«.p). 

10 the decision point 806 tests the accumulated path length or delay. 

A If the accumulated load is greater than the principal threshold as determined by decision 
point 805 



(C)lP>C,,p), 



the next link is obtained in 808. 

• If it is determined in decision point 804 that the link is not a principal link, the link is not considered 
and the next link is obtained in 808. 

20 In decision point 806. the accumulated path length up to this point Ldw is compared to the maximum 

path length Pr 

• If the accumulated path length Ldki is less than Pt, the hop count hf^ and the accumulated path 
length d^i are saved in a list (807), the node reached is also saved In order to proceed with the 
iteration at the next hop if necessary. 

25 • If the accumulated path length Zdht is equal to or greater than Pr. step 807 is bypassed and the 

data for this link is not added to the list. 
In either case, decision point 808 is then entered to determine if there are any more links exiting 
from this node. If so, step 803 is activated to get the next link and continue the process. If there are no 
more links exiting from this node, decision point 809 determines if the node is the destination node (j)- If 
30 so, the process is complete and terminates in 811. If this node is not the destination node (j), decision 
box 810 determines if there are any more nodes to be screened. If so, step 802 gets the next node and 
continue the process. If there are no more nodes to be screened, then the accelerated search has failed 
and the conventional search described in Figure 9 is started in 900. 

When the procedure of Figure 8 is complete, and destination node (j) has been reached, a list of the 
35 minimum hop counts and the path lengths tf^ is available. As discussed above. Routine B then 
backtracks through this list to identify the path with the minimum path delay as well as the minimum hop 
count. This is the optimum path to be used in sending the packets involved in the connection through the 
system of Figure 2. 

Note: When the Modified Bellman-Ford Algorithm is used to identify the principal paths, the same 
40 flow chart as shown in Figure 10 of Patent Application 93480030.1 is used. 
2. Conventional Version (Routine A2) 

Figure 9 shows a detailed flow chart of the Modified Bellman-Ford Algorithm used to perform the 
conventional search for an optimum path. Starting in 900, step 901 first sets the next node to the origin 
node (i). In 902, the data for the next node is retrieved from the Topology Database (306). In 903. the 
45 data for the next link leaving that node is obtained from the same Topology Database. Decision point 904 
determines whether that link is principal or not : 

• If the link is principal, decision point 905 compares the accumulated load 



CiV 



with the link principal threshold C^ap This accumulated load has been computed previously 
during the accelerated search algorithm and so can be reused here. 

■ If the accumulated load is equal to or less than the principal threshold, decision point 907 tests 
55 the accumulated path delay. 

■ If the accumulated toad is greater than the principal threshold, as determined by decision point 
905. the next link is obtained in 909. 
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= = > Pseudocode for principal linK handling: 
IF ikj) e PL r CyV available from routine A1 '/ 

IF CiV < Cm.p 

IF £c/m < Pt 

.... /* Continue phase A2 execution */ 



» is deter,.>ned in decision point 904 that the .inK is a secondary .in., 
the accumulated load 

C)i5' 



to the link secondary threshold C.s- secondary threshold, decision point tests 

^ If the accumulated load .s equal to or less 

the accumulated path delay. secondary threshold, as determined by decision 

. ,f the accumulated load is greater than the second y 

point 906, the next link is obtained in 909. 

= = > Pseudocode for secondary link handling: 
IF {kJHPL r Ci?' must be computed */ 

compute a?' /* complex computation involving CI)) 
and c */ 

IF CiV < Ck/.s 
IF £d», < Pt 

... /• continue phase A2 execution 'I 



,n decision point 907, the accumulated path length up to thi 
maximum path length Pt- 



is point is compared to 
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• If the accumulated path length is less than Pt, the hop count and the accumulated path length 
dki are saved in a list in step 908. 

• If the accumulated path length is equal to or greater than Ft, step 908 is bypassed and the data for 
this link is not added to the list. 

6 In either case, decision point 909 is then entered to deternnine if there are any more links exiting from 

this node. If so, step 903 gets the next link and continues the process. If there are no more links exiting 
from this node, decision point 910 is entered to determine if the node is the destination node (j)- if so. the 
process is complete and terminates in 912. If this node is not the destination node G). decision point 911 
then determines if there are any more nodes to be screened. If so, step 902 gets the next node and 

10 continues the process. If there are no more nodes to be screened, then no path is feasible, the process 
terminates in 912. 

When the procedure of Figure 9 is complete, a list of the minimum hop counts h/t and the path lengths 
dhi is available. As discussed above, Routine 8 then backtracks through this list to identify the path with the 
minimum path delay as well as the minimum hop count. This is the optimum path to be used in sending the 
75 packets involved in the connection through the system of Figure 2. 



Example of implementation 
Path Search in a Typical Network 

20 

Figure 10 shows a typical network used to illustrate the improvements provided by the present 
invention. It is a packet switched network comprising 33 nodes and 126 unidirectional high speed 
transmission links (63 trunks) of various capacity : T1 (1.5 Mbps). T3 (45 Mbps), El (2 Mbps), E3 (34 
Mbps), OC3 , STM1 (155 Mbps)... The average connectivity is two trunks per node with a minimum of one 

25 (Oslo, Edinburgh, Dublin, San Jose, Boston, Warsaw) and a maximum of eleven (Paris). The object of the 
present invention is to reduce the number of links potentially explored in searching for the optimum path 
between a source and a destination node. In our example, the source is Los Angeles (USA) and the 
destination is Milano (Italy). The Phase 1 of the route determination procedure identifies four principal paths 
with a minimal hop count of three : 

30 • Los Angeles - London - Zurich - Milano 

• Los Angeles - London - Paris - Milano 

• Los Angeles - Raleigh - Nice - Milano 

• Los Angeles - New York - Paris - Milano 

Once Phase 1 is successfully achieved. Phase 2 is executed to determine an optimum path : 
35 • Accelerated Version 

Figure 1 1 shows the number of links explored by the Modified Bellman-Ford Algorithm in Routine 
A1 object of the present invention. Only the principal links are considered to determine the path 
length and feasibility. In our example, the network is reduced to 10 links : Los Angeles - London, Los 
Angeles - Raleigh, Los Angeles - New York, Raleigh - Nice, Nice - Milano, London - Zurich. London - 
40 Paris, Paris - Milano, Zurich - Milano, New York - Paris. 

• Conventional Version 

Figure 12 shows the number of links explored by the Modified Bellman-Ford Algorithm used in 
Routine A of the the conventional Phase 2 described in European Patent Application 93480030.1. The 
search is not only limited to principal links but includes also secondary links. For example, Moscow 
45 can be reached in three hops. The secondary links New York - Berlin and Berlin - Moscow are visited 

by the algorithm in its search for the optimum path. In our case, 54 links have been explored which 
represents 80% of the network. 



Performances 

50 

To quantify the improvement resulting from the the new Path Selection procedure compared with the 
original version, a simulation has been done to estimate the performances of the path selection code 
running under a AIX Rise System/6000 workstation (compiled with XLC). An AIX tool providing, in output, 
the list of all instructions executed during the program and their usage frequency has been used. 
55 The simulated network is the one described in Figure 10. It comprises 33 nodes and 126 unidirectional 

links (63 trunks). Three tests have been run, first with the specifications detailed in European Patent 
Application 93480030.1 and secondly with the route determination procedure object of the present 
invention. The results of the computations are connpared in the table hereunder : the gain of performance in 
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term of executed instructions is about 15%. 



rest 



flops 



2 
3 
5 



Visited links in 
Phase 1 



22 
54 
63 



Executed Instructions 




Conventi'ona/ 

84.005 

189.331 

241.341 


Acce/erated 

73.604 

156.955 

199.723 


Gain 

13% 
17% 
17% 



75 



Note 



20 



. , „ „ha»s o. me pam sel««on procedure : Pl-.ee 1 remains 
Th,» re,u.« <*> t^JJ. accord » .he <-'«'''Z"Z<,^'^ »ou,d Pa 



Appendix 
25 Definitions 

: SZTefoXl^ortr^^^^^ „ ,^ ,^„«,o„ node 

: ,s m, hop ooon. « — raS^rdoes «nO a ,e.«e pa,h,. 

ZX:SLTXL^^Z-J^'^-L or„n « a. « des«n*n » nodes 

. ii :aL,d. oapap. o. .a « .«e„ no. « and nod, .„ .ad 

Threshold) , . jj^k (kl) as principal link in the route. 

• f i^dr^Jr^ra^d r .iiiri » pre..., c...«ed r^ea, 

. Current aUocaled load omink(kl) : 
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is the allocated load not taking 



the requesting connection into account. 
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Claims 

1. A network access node (300) in a packet switching communication network (200) comprising a plurality 
of nodes (201 ..208) interconnected with transmission links (209). said node including : 

5 • means for receiving and transmitting data packets (301, 302, 304). 

• nneans for storing and updating the network configuration (306), 

• nneans, in a first phase (503), for : 

■ identifying principal paths including minimal hop count and minimal transmission delay Zdkt 
between an originating node and a destination node in said network, 

10 ■ identifying principal and secondary links, 

• means, responsive to said means for identifying principal paths and links, for determining, in a 
second phase (504). an optimal path between said originating and destination nodes, 

and characterized in that said means for determining, in said second second phase (504), an 
optimal path comprises : 
75 • means for determining an optimal path using only principal links (701, 704). 

2. A network access node (300) according to claim 1 wherein said means for determining, in said second 
phase, an optimal path comprises a further means 

for determining an optimal path using principal and secondary links (703. 704) when the destination 
20 node is not reached (702) using only said principal links. 

3. A network access node (300) according to claim 2 wherein : 

said means for determining an optimal path on principal and secondary links, is using link utilization 
data previously computed on principal links by said means for determining an optimal path on said 
25 principal links. 

4. A network access node (300) according to anyone of claims 1 to 3 comprising 

means for limiting the transmission delay in said optimal path to a preselected threshold P7(505). 

30 5. A network access node (300) according to anyone of claims 1 to 4 wherein 

said means for determining an optimal path between said originating and destination nodes 
comprises a Modified Bellman-Ford algorithm (701, 703). 

6. A method in an access node (300) for determining an optimal routing path between an originating node 
35 and a destination node in a packet switching communication network (200) comprising a plurality of 

nodes (201. .208) interconnected with transmission links (209). said method involving the steps of : 

• storing and updating the network configuration (306). 

• in a first phase (503) : 

■ identifying principal paths including minimal hop count and minimal transmission delay Ldhi 
40 between said originating node and said destination node in said network, 

■ identifying principal and secondary links, 

• determining, in a second phase (504) and in response to said step of identifying principal paths 
and links, an optimal path between said originating and destination nodes, 

and characterized in that said second phase (504) for determining an optimal path comprises the 
45 step of : 

• determining an optimal path using only principal links (701 , 704). and 

7. The method according to claim 6 wherein said second phase (504) for determining an optimal path 
comprises the further step of : 

50 determining, when the destination node is not reached (702) using only said principal links, an 

optimal path using principal and secondary links (703. 704). ' \ 

8. The method according to claim 7 wherein 

said step of determining an optimal path on principal and secondary links, is using link utilization 
55 data previously computed on principal links by said step of determining an optimal path on said 

principal links. 
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a Modified BeUman-Ford algorithm. 
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